package com.linyaonan.leetcode.sword_to_offer._55_1;

/**
 * 输入一棵二叉树的根节点，求该树的深度。从根节点到叶节点依次经过的节点（含根、叶节点）形成树的一条路径，最长路径的长度为树的深度。
 *
 * 例如：
 *
 * 给定二叉树 [3,9,20,null,null,15,7]，
 *
 *     3
 *    / \
 *   9  20
 *     /  \
 *    15   7
 * 返回它的最大深度 3 。
 *
 *  
 *
 * 提示：
 *
 * 节点总数 <= 10000
 *
 * 来源：力扣（LeetCode）
 * 链接：https://leetcode.cn/problems/er-cha-shu-de-shen-du-lcof
 * 著作权归领扣网络所有。商业转载请联系官方授权，非商业转载请注明出处。
 */
class Solution {

    int max = 0;
    /**
     * 直接遍历二叉树，记录当前的层数
     * @param root
     * @return
     */
    public int maxDepth(TreeNode root) {
        if (root == null) {
            return 0;
        }
        bfs(root, 0);
        return max;
    }

    private void bfs(TreeNode node, int count) {
        if (node == null) {
            return;
        } else {
            count++;
            max = Math.max(max, count);
            bfs(node.left, count);
            bfs(node.right, count);
        }
    }
}